package com.algorithm.ch1.cjm.other;

/**
 * 有效的括号
 * 给定一个只包括 '('，')'，'{'，'}'，'['，']' 的字符串，判断字符串是否有效。
 * <p>
 * 有效字符串需满足：
 * <p>
 * 左括号必须用相同类型的右括号闭合。
 * 左括号必须以正确的顺序闭合。
 * 注意空字符串可被认为是有效字符串。
 *
 * @Author: Jie Ming Chen
 * @Date: 2018/9/16
 * @Version 1.0
 */
public class IsValid {

    public static void main(String[] args) {
        boolean valid = new IsValid().isValid("{[]}()");

        System.out.println(valid);
    }

    /**
     * 思路：找到匹配的就去掉它
     * @param str
     * @return
     */
    public boolean isValid(String str) {

        if (str == null) {
            return false;
        } else if (str.length() == 0) {
            return true;
        }

        while (true) {
            int length = str.length();

            str = str.replaceAll( "\\{}", "");
            str = str.replaceAll("\\(\\)", "");
            str = str.replaceAll("\\[]", "");

            if (str.length() == length) {
                return false;
            } else if (str.length() == 0) {
                return true;
            }
        }
    }
}
